const db = require("../db/index");
const jwt = require("jsonwebtoken");
const config = require("../config");
exports.regUser = (req, res) => {
  const userinfo = req.body;
  sql = `select * from ev_users where username=?`;
  db.query(sql, [userinfo.username], function (err, results) {
    // 执行 SQL 语句失败
    if (err) {
      return res.cc(err);
    }
    // 用户名被占用
    if (results.length > 0) {
      return res.cc("用户名被占用，请更换其他用户名！");
    }
    // TODO: 用户名可用，继续后续流程...
    const sql = "insert into ev_users set ?";
    db.query(
      sql,
      { username: userinfo.username, password: userinfo.password },
      function (err, results) {
        // 执行 SQL 语句失败
        if (err) return res.send({ status: 1, message: err.message });
        // SQL 语句执行成功，但影响行数不为 1
        if (results.affectedRows !== 1) {
          return res.cc("注册用户失败，请稍后再试！");
        }
        // 注册成功
        res.send({ status: 0, message: "注册成功！" });
      }
    );
  });
};

exports.login = (req, res) => {
  const userinfo = req.body;
  const sql = `select * from ev_users where username=?`;
  db.query(sql, userinfo.username, function (err, results) {
    // 执行 SQL 语句失败
    if (err) return res.cc(err);
    // 执行 SQL 语句成功，但是查询到数据条数不等于 1
    if (results.length !== 1) return res.cc("登录失败！");
    // TODO：判断用户输入的登录密码是否和数据库中的密码一致
    if (userinfo.password !== results[0].password) {
      return res.cc("登录失败!");
    }
    const user = { ...results[0], password: "", user_pic: "" };
    const tokenStr = jwt.sign(user, config.jwtSecretKey, {
      expiresIn: "10h",
    });
    res.send({
      status: 0,
      message: "登录成功！",
      // 为了方便客户端使用 Token，在服务器端直接拼接上 Bearer 的前缀
      token: "Bearer " + tokenStr,
    });
  });
};
